// 用于列表的渲染
<template>
  <div>
    <!-- 
      本例展示如何获取和设置选中节点。获取和设置各有两种方式：通过 node 或通过 key。如果需要通过 key 来获取或设置，则必须设置node-key
      row-key	行数据的 Key，用来优化 Table 的渲染；在使用 reserve-selection 功能与显示树形数据时，该属性是必填的。
      default-expand-all	是否默认展开所有行，当 Table 包含展开行存在或者为树形表格时有效
      tree-props	渲染嵌套数据的配置选项   默认值{ hasChildren: 'hasChildren', children: 'children' }
     -->
    <el-table
      :data="menuList"
      border
      style="width: 100%"
      default-expand-all
      :tree-props="{ children: 'children' }"
      row-key="id"
    >
      <el-table-column prop="id" label="菜单编号" width="180">
      </el-table-column>
      <el-table-column prop="title" label="菜单名称" width="180">
      </el-table-column>
      <el-table-column prop="pid" label="上级菜单"> </el-table-column>
      <el-table-column prop="icon" label="菜单图标" width="180">
      </el-table-column>
      <el-table-column prop="url" label="菜单地址" width="180">
      </el-table-column>
      <el-table-column label="状态">
        <template slot-scope="item">
          <!-- tag标签 -->
          <div>
            <el-tag v-if="item.row.status == 1" type="success">启 用</el-tag>
            <el-tag v-else type="danger">禁 用</el-tag>
          </div>
        </template>
      </el-table-column>
      <el-table-column label="操作">
        <template slot-scope="item">
          <div>
            <el-button type="primary" size="small" @click="edit(item.row.id)"
              >编辑</el-button
            >
            <!-- {{item.row}}    代表要删除的每一条数据 -->
            <!-- 可以根据指定的 菜单编号(id) 进行删除-->
            <el-button type="danger" size="small" @click="del(item.row.id)"
              >删除</el-button
            >
          </div>
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

<script>
import { mapActions, mapGetters } from "vuex";
// 引入接口文档
import { deleteMenu } from "../../util/axios";
export default {
  data() {
    return {
      /*
       tableData: [{
          date: '2016-05-02',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }, {
          date: '2016-05-04',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1517 弄'
        }] 
        */
    };
  },
  computed: {
    ...mapGetters({
      menuList: "menu/getMenuList",
    }),
  },
  mounted() {
    //当列表渲染触发行动
    this.getMenuList();
  },
  methods: {
    ...mapActions({
      getMenuList: "menu/getMenuListAction",
    }),
    // 删除按钮事件
    del(id) {
      this.$confirm("请确定是否删除？", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(() => {
          // 调取删除接口
          deleteMenu({
            id,
          }).then((res) => {
            if (res.data.code === 200) {
              this.$message.success(res.data.msg);
              //当列表删除成功触发行动（刷新页面）
              this.getMenuList();
            } else {
              this.$message.error(res.data.msg);
            }
          });
        })
        .catch(() => {
          this.$message({
            type: "info",
            message: "已取消删除",
          });
        });
    },
    // 封装一个编辑事件
    edit(id) {
      // 告诉父组件，要打开编辑弹框顺便传一个id
      this.$emit("edit", id);
    },
  },
};
</script>

<style lang="" scoped>
</style>
